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(57) A disk (31) conforms to a fixed length format 
and a storage subsystem (3) shapes a CKD format 
record from a host computer (1 ) in a fixed length unit to 
store shaped data therein. A format conversion program 
(24) reads a fixed length block from the disk (31) and 
extracts the shaped CKD format data to obtain such 
information to access a file system as file management 
information to thereby access the file system. Moreover, 
in an operation to write data on the disk (31), the data 
which the storage subsystem has received from the 
host computer (2) is shaped in the conversion program 
(24) into a sequence of data in a format to be written on 
the disk (31) and then the sequence of data is written in 
a fixed length format thereon. Resultantly, data can be 
shared between systems using mutually different data 
formats to store data in storages. 
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Description 

BACKGROUND OF THE INVENTION 

5 [0001] This application is related to U.S. application Serial No. 08/774,447 filed December 30, 1996 and U.S. appli- 
cation Serial No. 08/912,872 filed August 19, 1997, contents of which are incorporated herein by reference. 
[0002] The present invention relates to a storage subsystem in an information processing system, and in particular, 
to a storage subsystem including a plurality of interfaces conforming to a plurality of data formats. 
[0003] Recently, there has been intensively achieved "downsizing" of computer systems in which jobs conventionally 

w conducted by a mainframe are carried out by small-sized computers such as personal computers and workstations. In 
the mainframe, there has been accumulated a large amount of information through jobs conducted in the past. In this 
situation, it is desired that the information accumulated in the mainframe is accessed from small-sized computers. Here- ) 
tofore, there has been known a technology in relation to file sharing or file conversion between different operating sys- 
tems in which/for example, an operating system of a workstation accesses a file of a file system created by an operating 

is system of a personal computer. For some of the personal computer file systems, information such as file formats and 
positions of file management information are generally opened. Therefore, the workstation operating system can inter- 
pret a file format of a personal computer in the workstation to access a file in a file system created by the personal com- 
puter operating system. 

[0004] In the mainframe, a disk access is conventionally accomplished in the count-key-data (to be abbreviated as 
20 CKD herebelow) format; whereas, a fixed length data (to be abbreviated as FBA format herebelow) format is used for 
the disk access in the open system. Consequently, to share a file between the main and open systems, it is required to 
absorb the difference between the data formats. JP-A-9-258908 (corresponding to US Patent Application Serial No. 
08/774,447) describes a technology to absorb the data format discrepancy. That is, there is provided a storage having 
a function in which when the open system reads a record written in the CKD format in the storage, the data is presented 
25 as data in a fixed length format, namely, the data is shaped in a particular format. Additionally, on the open system side, 
there is disposed means to interpret the fixed length data thus shaped in the particular format to thereby obtain a data 
field therefrom. With this provision, it is possible for the open system to read a data set written in the storage by the 
mainframe. 

30 SUMMARY OF THE INVENTION 

[0005] Although JP-A-9-258908 (corresponding to US Patent Application Serial No. 08/774,447) describes a method 
for the open system to read a data set from the mainframe, no description has been given of a method of writing data 
in a file system of the mainframe. On the open system side, there exists neither a concept of the count field of the CKD 
35 data nor a concept for the cylinder and the head described therein. Therefore, for the open system side to write the CKD 
data, there is required means to create a count field on the open system side. Moreover, for the mainframe side to read 
a data set written on the open system side, it is necessary to update, for example, management system of the file sys- 
tem generated on the mainframe side. 

[0006] It is therefore an object of the present invention to provide an interface conforming to the CKD format and an 
40 interface conforming to the FBA format in a disk device so that the open system writes data in the file system of the 
mainframe. 

[0007] In order to achieve the object above, there is provided a computer system in accordance with the present 
invention. The computer system in accordance with the present invention includes a first computer, a second computer, 
and a storage subsystem having a plurality of interfaces to establish connections to the first and second computers. The 

45 first computer accesses the storage subsystem in accordance with a count-key-data format and the second computer 
accesses the storage subsystem in accordance with a fixed length block format. The second computer includes access 
means for accessing a record in the count-key-data format, which is written by the first computer in the storage subsys- 
tem, via an interface conforming to a fixed length block format, acquiring means for acquiring only user data from the 
record read by the accessing means, and interpreting and using means for interpreting and utilizing management infor- , 

so mation of a file system and the like written in a record generated in the storage subsystem by the first computer. In addi- 
tion, the second computer includes writing means for converting write data into a record in the count-key-data format 
and writing the record in the storage subsystem via an interface conforming to a fixed length block format. 
[0008] Furthermore, in the data writing operation, the writing means of the second computer refers to management 
information of a file produced by the first computer in the storage subsystem, interprets a data format of the file, and 

55 writes therein records conforming to a data format of the file. Furthermore, by rewriting the management information of 
the file at completion of the writing operation of the second computer, it is possible for the first computer to read the 
record written by the second computer. 

[0009] Moreover, the storage subsystem of the computer system in accordance with the present invention has a one- 
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to-one correspondence between an address specified by a cylinder number and a head number in the count-key-data 
format and an address specified by a logical block number in the fixed length block format. The writing means of the 
second computer handles requested data as a record in the count-key-data format, generates a count field of a record 
in the count-key-data format in accordance with an address of a write position to thereby obtain through conversion a 
5 record in the count-key-data format, and calculates a logical block number in a fixed length format in association with a 
cinder number and a head number for a writing operation in the storage subsystem so as to access the etc rag a cub 
system in accordance with the logical block number. 

[0010] Additionally, in accordance with the present invention, the storage subsystem of the computer system includes 
a storage to store data in the fixed length block format, and the first computer includes writing means which converts a 

10 record written by the first computer via the count-key-data interface in a file into a sequence of data in the fixed length 
block format in a predetermined format to thereby write the sequence of data in the storage. Moreover, the writing 
means of the second computer includes means similar to means of the storage subsystem to convert a record into a 
sequence of data in the fixed length block format such that the converted sequence of data in the fixed length block for- 
mat is written in the storage subsystem via an interface conforming to the fixed length block format. 

75 [001 1 ] Furthermore, the writing means divides the record in the counter-key-data format into fixed-length blocks for 
the writing thereof. When last one of the divided records has a length less than the fixed length, a predetermined 
sequence of data is added thereto beginning at the end of data to resultantly obtain a fixed length block so as to write 
the block in the storage subsystem. 

20 BRIEF DESCRIPTION OF THE DRAWINGS 

[001 2] The objects and features of the present invention will become more apparent from the consideration of the fol- 
lowing detailed description taken in conjunction with the accompanying drawings in which: 

25 Fig. 1 is a configuration diagram showing constitution of a disk storage system in accordance with the present 
invention; 

Fig. 2 is a diagram showing a layout of CKD format data stored in a storage subsystem; 
Fig. 3 is a diagram showing a data layout of data sets stored in a disk device; 
Fig. 4 is a flowchart showing an open processing of a data set; 
30 Fig. 5 is a flowchart showing a write processing of a data set; and 
Fig. 6 is a flowchart showing a close processing of a data set. 

DESCRIPTION OF THE PREFERRED EMBODIMENTS 

35 [0013] Fig. 1 shows a configuration example of a computer system in accordance with the present invention. The 
computer system includes a host computer 1, a host computer 2, and a storage subsystem 3 connected to the host 
computers 1 and 2. 

[0014] The host computer 1 includes a count- key-data (to be abbreviated as CKD herebelow) interface 1 1 as an inter- 
face for the storage'subsystem 3 and operates in accordance with the CKD format, and the host computer 1 is control- 
40 led by an operating system 12. Additionally, the system includes an application program 13 which operates under 
control of the operating system 12. Although there exist other inevitable constituent elements such as a central process- 
ing unit (CPU) in the computer, these elements are not particularly important in the description of the embodiment of 
the invention and hence will not be described in this application. 

[001 5] On the other hand, the host computer 2 includes a fixed length data interface 1 1 as an interface for the storage 
45 subsystem 3 and operates in accordance with the fixed length block format, and the host computer 2 is controlled by an 
operating system 22. Moreover, there exist an application program 23 and a format conversion program 24 which oper- 
ate under control of the operating system. 

[0016] The storage subsystem 3 includes a disk 31 , a CKD interface 32 to be linked with the host computer 1 , and a 
fixed length interface 33 to be connected to the host computer 2. 
so [0017] In the fixed length format, each data is stored in an area called "block". Each block is of a fixed length, e.g., 
512 bytes and is assigned with a block number (to be abbreviated as LBA herebelow), the number being used for the 
accessing of the block. 

[0018] On the other hand, in the CKD format, a record is accessed in accordance with specifications of a cylinder 
number (CC), a head number (HH), and a record number (R). A minimum access unit is one record. In the following 
55 description, a record address expressed by the cylinder, head, and record numbers is referred to as CCHHR and a track 
address represented by a cylinder number and a head number is called CCHK In the CKD format, one record includes 
a count field (to be referred to as field C herebelow), a key field (to be referred to as field K), and a data field (to be 
referred to as field D herebelow). Field C includes CCHHR and lengths of fields K and D and is of a fixed length in any 
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case. Each of fields K and D is of a variable length and has a length written in field C. One track includes a plurality of 
records. However, since the track has a fixed length, when the records have mutually different lengths, the number of 
records per track varies between the tracks. Information of the number of records and positions thereof in the track are 
not managed. Consequently, when a record at an intermediate point of the track is desired to be accessed, it is neces- 
5 sary to read the records beginning at the first position, i.e., to read the count field so as to obtain the position of the next 
record. 

[0019] Additionally, one cylinder includes a plurality of tracks. The number of tracks per cylinder is fixed. 
[0020] Fig. 2A shows data allocation in a track on a general CKD disk device and Fig. 2B shows a data format to store 
data in the CKD format in the storage subsystem of the embodiment of the invention. The disk 31 conforms to a fixed 
w length data format, and data in the CKD format is converted into data in fixed length data format to be stored in the stor- 
age. 

[0021] In Fig. 2A, HA 51 indicates a home address to represents, for example, a state of a track. ROC 52 is a count 
field of record 0 and ROD 53 denotes a data field of record 0 in which it is not allowed to store user data. R1C 54 t R1 K 
55, and R1 D 56 are respectively a count field, a key field, and a data field of record 1 . Between each fields, there exits 
75 a fixed-length area called "gap" in which data is not stored, namely, the gap is a demarcation to separate the fields from 
each other. Moreover, at an end of each of fields C, K, and D, there is additionally provided an error correction code 
(ECC) 60. The contents, ECC, and gap of field C are generated in the disk device. 

[0022] In the storage subsystem, HA 51 , ROC 52, and ROD 53 of each track are gathered to be stored in an area such 
that HA 51 , ROC 52, and ROD 53 are invisible via the fixed length interface 33. When accessing LBA0 from the interface 
20, 33, the access is made to the first position as indicated by cylinder number 0, head number 0, and record number 1 . 
When one record exceeds the size of one block as R1D of Fig. 2, data is consecutively written in the next block, i.e., 
LBA1 62. In the record, no gap exists between fields C, K, and D. Since the size of each record does not necessarily 
match the boundary of the fixed length block, an area from the end of record to the end of block is filled with blank 65, 
i.e., 0 is arranged therein for a gap. Record 2 then begins with the next block, LBA2 63. When the host computer 1 
25 writes a record in the storage subsystem 3, the CKD interface 32 generates ECCs to be added to fields C and D at their 
end position and the blank 65 is added to form a fixed length block so as to write the record on the disk 31 . Although 
the contents of the blank are not limited, 0 is used in this embodiment. In a reading operation, the CKD interface 32 
v reads a fixed length block, extracts fields K and D, and passes these fields to the host computer 1 . Therefore, the host 

r computer 1 is not required to consider the write data format and the position of the record on the disk 31 . On the other 

fc 30 hand, in an operation in which the host computer 2 read a record from the storage subsystem 3, for example, LBA0 of 

If Fig. 2B, since the reading operation can be conducted only in the unit of one block, all of the contents of LBA0, i.e., the 

* contents including field C and ECC are transferred to the host computer 2. In a data writing operation, data transferred 

from the host computer 2 is directly written in LBA0. 

[0023] The track length is an integral multiple of the block length and hence each block includes an identical number 
35 of blocks. When the end of record in the track is other than the end of track, 0 is filled therein up to the end of track so 
that all tracks includes the same number of blocks. In addition, each cylinder includes an identical number of tracks. 
[0024] Consequently, to access the first position of CCHHR = (C, H, 1), it is only necessary to calculate 



LBA = (Cx no. of tracks per cylinder + H) x no. of blocks per track (1) 



40 



[0025] Fig. 3 shows information and files (data sets) of a file system created on the disk 3 by the host computer 1 . 
Disposed at a particular position of the disk 31 is a volume label 71 in which a write address of a volume table of con- 
tents (VTOC 72) is written in the form of CCHHR. In the VTOC 72, there is entirely recorded management information 
of data sets written on the disk 31 , for example, a set of records each including a 44-byte key field and a 96-byte data 
45 field. The key field includes a data set name and the data field includes information such as positional information of the 
data set. As the positional information, there are written a record length, a position of an extent, and a position of a last 
record written in the extent. One set of these data items is referred to as DSCB. 

[0026] A data set is located in an area called "extent". An extent is a consecutive area including a plurality of tracks. 
Depending on situations, one extent or two or more extents is or are arranged for a data set. When a plurality of extents 

so are arranged, these extents need not exist in a continuous area. 

[0027] When the application program 1 3 of the host computer 1 reads a data set, an access start position and a last 
record position are obtained from positional information of the pertinent data set in the VTOC 72 and determines 
CCHHR of a read position to thereby read the data set. These processing steps are carried out by the operating system 
12. Moreover, although the data on the disk 31 includes information of filed C and ECC which are unnecessary for the 

55 host computer 1 , the portion thereof is removed by the CKD interfaces 1 1 and 32. Namely, only the actual data of fields 
K and D are passed to the operating system 12 of the host computer 1 and the unnecessary information is not trans- 
ferred thereto. 

[0028] On the other hand, the operating system 22 of the host computer 2 knows neither the structure of the file sys- 
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tern of the. host computer 1 nor the configuration of CKD format data stored on the disk 31, it is impossible in this case 
to use the method of accessing a file system of the host computer 2. To overcome this difficulty, there is provided a for- 
mat conversion program 24 such that the application program 23 of the host computer 2 accesses a data set of the host 
computer 1 via the program 24. The program 24 has a method similar to the method used by the storage subsystem 3 
5 to write CKD format data on the disk 31 and to read CKD data from the disk 31 . The program 24 includes a procedure 
to read data in a block unit from the storage subsystem 3 so as to obtain an actual data portion from the data in a format 
shown in Fig. 2B and a procedure in which the data passed from the application program 23 is regarded as a record to 
be converted into a CKD record such that the CKD record is further transformed into an FBA format record to be written 
on the disk 31 . Additionally, the format conversion program has a procedure to interpret management information of a 
re data set written in the VTOC 72 to obtain a position at which the data set is written. Next, referring to flowcharts, descrip- 
tion will be given of a flow of a writing operation conducted by the conversion program 24 on a data set in three sections 

f ~ of open, write, and close processing. 

[0029] Fig. 4 is a flowchart of processing in which the program 24 opens a data set. 

[0030] The program 24 has a track buffer to keep one-track data therein, a block buffer to keep therein data of blocks 
.* 15 corresponding to one DSCB, a set (called a record pointer) of a track number and a record number of a data set to be 

accessed, and a pointer (called a buffer pointer) indicating a position in the track buffer of the record number designated 
by the record pointer. In the open processing, a track including the volume label 71 is first read to check the position of 
VTOC. The label 71 exists at a fixed position in any cases, and the conversion program 24 beforehand knows the posi- 
tion presented by CCHHR on the disk 31 of the volume label 71 . For example, assume that the volume label 71 exists 
20 at a position represented as cylinder number 0, head number 0, and record number 3. The program 24 calculates, in 
accordance with expression (1), LBA for cylinder no. 0 and head no. 0, namely, LBA no. 0 (step 101) and then reads 
blocks of one track beginning at the position and stores the blocks in the track buffer (step 102). Subsequently, by 
^ checking the field C of record 1 existing at a first position of the obtained block and then the length of field D, there is 

obtained a block position in which record 2 is stored (step 103). Thereafter, the operation above is again conducted, 
25 namely, the first field of record 2 is read to obtain the length of field D in accordance with field C to thereby check a block 
position of record 3 (step 104). As a result, field D of record 3 is known. 

[0031] Next, a storage position of VTOC 72 is read from field D of record 3 (step 105) to calculate, according to 
expression (1), LBA corresponding to the position (step 106). Thereafter, blocks of one track are read beginning at the 
LBA to be moved to the track buffer (step 1 07). Subsequently, a retrieval is made through the track buffer to attain a data 
30 set name for the open processing. In a counter r prepared, an initial value of one is set to r (step 108). The key field of 
record r of the obtained track is checked to determine whether or not the key field matches with the name of the objec- 
tive data set (step 109). When a pertinent record is detected, a storage position of the data set is obtained from field D 
to entirely store fields C, K, and D of the record in an internal buffer (step 110). When the record is missing, the value 
* of r is incremented by one (step 115) and control is passed to step 109 to retrieve a subsequent record. In addition, if 

t * £ 35 the record is missing even when the check is conducted up to the end of track of the pertinent track, a track subsequent 

thereto is read from the disk to conduct a retrieval beginning at record 1 (steps 1 13 and 114). 

[0032] Additionally, the write processing will be described by referring to Fig. 5. The format conversion program 24 
receives a record length and contents of data from the application program 23 and then executes the write processing 
in a record unit. However, since the write operation on the disk 31 is carried out in a one-track unit which is an integral 
40 multiple of blocks. Therefore, if write requests were issued in the past, data received for the write requests are kept 
stored in the track buffer. In the write processing, a check is first made to determine whether or not the pertinent data 
< 'c: received can be written in the track buffer (step 201 ). If the data cannot be written therein, the contents of the present 

track buffer ranging from the write position to the buffer end are cleared to zero (step 202), the track buffer is written in 
the storage subsystem 3 (step 203), the buffer pointer is reset to the first position of the track buffer (step 204), and then 
45 the record pointer is set to record 1 of the next track (step 205). The contents created in the track buffer are directly writ- 
ten on the disk 31. 

[0033] In step 206 and subsequent steps, there is conducted processing to write CKD format data in the track buffer. 
First, information of field C is generated in accordance with the record pointer and the record length to be then written 
at a position of the track buffer indicated by the buffer pointer (step 206), and the received data is written therein after 
so field C (step 207). The next record is to be written therein beginning at the first position of the next block. In conse- 
quence, when the block is not full of data, 0 is filled therein up to the first position of the next block (step 208). Finally, 
the buffer pointer is set to the first position of the next block (step 209) and then the record pointer is set to the next 
record (step 210). 

I [0034] Subsequently, the close processing of the format conversion program 24 will be described by referring to Fig. 

55 6. First, a check is made to determine whether or not data has been written in the track buffer by the write processing 
conducted up to this point (step 301 ). If the data has been written therein, the contents of the buffer beginning at a posi- 
tion indicated by the current buffer pointer to the end of the track buffer are cleared to zero (step 302) and then the track 
buffer is written on the disk (step 303). Next, to rewrite the last record position in VTOC 72, information of the last record 
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position is rewritten in the contents of the stored block buffer (step 304) and then the block buffer is written on the disk 
(step 305). With this operation, the close processing is completed. 

[0035] In accordance with the computer system of the present invention, data can be shared between systems oper- 
ating in accordance with storage procedures of mutually different data formats, namely, of the CKD and FBA formats. 
This advantageously enables a flexible data exchanging operation to be achieved with an increased performance. 
[0036] While the present invention has been described with reference to the particular illustrative embodiments, it is 
not to be restricted by those embodiments but only by the appended claims. It is to be appreciated that those skilled in 
the art can change or modify the embodiments without departing from the scope and spirit of the present invention. 

Claims 

1 . A computer system control method of controlling a computer system including a first computer (1 ), a second com- 
puter (2), and a storage subsystem (3) having a plurality of interfaces (32, 33) to be connected connect to the first 
and second computers, comprising the following steps of: 

accessing by the first computer the storage subsystem via an interface conforming to a count-key-data format 
and configuring a record in the count-key-data format; and 

reading and writing data by the second computer via an interface conforming to a fixed length block format. 

2. A computer system control method in accordance with claim 1 , further including the step of 

referring, by the second computer, to management information of a file produced by the first computer in the 
storage subsystem and writing therein records conforming to a data format thereof. 

3. A computer system control method in accordance with claim 1 , further including the step of 

rewriting by the second computer, in response to a rewriting of user data, file management information corre- 
sponding to the user data written by the first computer in the storage subsystem. 

4. A computer system control method in accordance with claim 1, wherein the storage subsystem has a one-to-one 
correspondence between an address specified by a cylinder number and a head number in the count- key-data for- 
mat and an address specified by a logical block number in the fixed length block format, the method further includ- 
ing the steps of: 

handling, by the second computer, requested data as a record in the count-key-data format; 

recognizing a write position of the record in accordance with a cylinder number, a head number, an a record 

number in the count-key-data format; 

generating a count field in the count- key-data format in accordance with the write position and thereby obtain- 
ing through conversion a record in the count-key-data format, and 

calculating a logical block number in a fixed length format in association with the cylinder number and the head 
number. 

5. A computer system control method in accordance with claim 1 , further including the steps of: 

converting, by the storage subsystem, a record written by the first computer via the count-key-data interface in 
a file into a sequence of data in the fixed length block format; and 
writing the sequence of data in the storage. 

6. A computer system control method in accordance with claim 5, further including the steps of: 

dividing, by the storage subsystem, the record in the counter-key-data format into fixed-length blocks for the 
writing thereof; and 

adding to any block having a length less than the fixed length a predetermined sequence of data to obtain a 
fixed length block, thereby writing the data therein. 
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